package com.lazyJr.test.sort;

/**
 *
 * 可以看出是插入排序的一种优化，或者是预处理。
 * 希尔排序就是先进行h-sort，也就是让间隔为h的元素都是有序的。普通的插入排序就是1-sort。
 *
 * Created by liuyangfx on 16-3-14.
 */
public class ShellSort {
    public void sort(int[] a){
        int h=1;
        while(h<a.length/3){
            h=3*h+1;
        }
        while(h>=1){
            for(int i=h;i<a.length;i++){
                for(int j=i;j>=h;j=j-h){
                    if(less(a[j],a[j-h])){
                        exch(a,j,j-h);
                    }
                    else break;
                }
            }
            h=h/3;
        }
    }

    private boolean less(int v,int w){
        return (v - w) < 0;
    }

    private void exch(int[] a,int i,int j){
        int temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
}
